// 蜂窝蜜造平台生成代码，如手工更改，请添加到 .beeignore 忽略生成

package com.fowo.api.service;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fowo.api.common.model.ImportRow;
import com.fowo.api.common.model.OptionItem;
import com.fowo.api.entity.WarehouseBinProducts;
import com.fowo.api.model.warehouse.bin.products.WarehouseBinProductsImportPo;
import com.fowo.api.model.warehouse.bin.products.WarehouseBinProductsItemVo;
import com.fowo.api.model.warehouse.bin.products.WarehouseBinProductsItemVoPages;
import com.fowo.api.model.warehouse.bin.products.WarehouseBinProductsSearchParamPo;
import com.fowo.api.model.warehouse.bin.products.WarehouseBinProductsVo;
import com.fowo.api.sys.entity.SysFile;
import java.util.Date;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.multipart.MultipartFile;

/**
 * 仓位子表 服务类
 */
public interface WarehouseBinProductsService {
  /**
   * 创建仓位子表
   * @param model 仓位子表
   * @return 新数据的主键
   */
  Long create(WarehouseBinProductsVo model) throws Exception;

  /**
   * 更新仓位子表
   * @param model 仓位子表
   * @return 更新是否成功
   */
  boolean update(WarehouseBinProductsVo model) throws Exception;

  /**
   * 更新仓位子表（带空值）
   * @param model 仓位子表
   * @return 更新是否成功
   */
  boolean updateForEdit(WarehouseBinProductsVo model) throws Exception;

  /**
   * 查询是否后台下载
   */
  boolean getBackgroundExportFlag(WarehouseBinProductsSearchParamPo search);

  /**
   * 删除仓位子表
   * @param id 仓位子表的主键
   * @return 删除是否成功
   */
  boolean delete(Long id) throws Exception;

  /**
   * 批量删除仓位子表
   * @param ids 仓位子表的主键列表
   * @return 删除是否成功
   */
  boolean batchDelete(List<Long> ids) throws Exception;

  /**
   * 获取详情
   * @param id 仓位子表的主键
   */
  WarehouseBinProductsVo getVoById(Long id) throws Exception;

  /**
   * 分页查询仓位子表
   * @param search 查询条件
   * @return 仓位子表分页查询结果
   */
  Page<WarehouseBinProductsItemVo> pageSearch(
    WarehouseBinProductsSearchParamPo search
  );
  /**
   * 导入预览
   * @param sysFile 已上传到系统的文件
   * @param templateId 要使用的模版编号
   * @param allowOverrides 允许覆盖
   */
  List<ImportRow<WarehouseBinProductsImportPo>> importPreview(
    SysFile sysFile,
    Long templateId,
    boolean allowOverrides
  ) throws Exception;

  /**
   * 完成导入
   * @param rows 预导入的行信息
   * @param templateId 当前导入模版（可空）
   */
  void importDone(
    List<ImportRow<WarehouseBinProductsImportPo>> rows,
    Long templateId
  ) throws Exception;
  /**
   * 导出
   * @param templateId 使用模版（可以是 null 或 0 表示系统默认导出模版）
   * @param search 查询条件
   */
  void export(
    Long templateId,
    WarehouseBinProductsSearchParamPo search,
    HttpServletResponse response
  ) throws Exception;

  /**
   * 通过 产品 查询 仓位子表 的主键
   * @param productId 产品
   */
  Long getIdByProductId(Long productId);
  /**
   * 通过 产品 查询 仓位子表 的主键列表
   * @param list 产品
   */
  List<Long> getIdsByProductId(List<Long> list);
  /**
   * 通过  仓位子表 的主键查询 产品
   * @param id 主键
   */
  Long getProductIdById(Long id);
  /**
   * 通过  仓位子表 的主键查询 产品 列表
   * @param ids 主键
   */
  List<Long> getProductIdByIds(List<Long> ids);
  /**
   * 列表查询仓位子表
   * @param search 查询条件
   * @return 仓位子表列表查询结果
   */
  List<WarehouseBinProductsItemVo> search(
    WarehouseBinProductsSearchParamPo search
  );
  /**
   * 仓位子表快速查询选项(有缓存)
   * @param search 查询条件
   * @return 仓位子表选项结果
   */
  List<OptionItem<WarehouseBinProductsItemVo>> searchOptions(
    WarehouseBinProductsSearchParamPo search
  );
  /**
   * 查询仓位子表最后更新时间
   * @param search 查询条件
   * @return 仓位子表列表查询结果
   */
  Date searchLastUpdateTime(WarehouseBinProductsSearchParamPo search);
  /**
   * 批量更新 仓位 下属数据
   */
  void saveAllByParentWarehouseBin(
    Long parentWarehouseBin,
    List<WarehouseBinProductsItemVo> list
  ) throws Exception;
  /**
   * 返回 仓位 下属多级分页
   */
  Map<String, Page<WarehouseBinProductsItemVoPages>> pagesByParentWarehouseBin(
    WarehouseBinProductsSearchParamPo search
  );
  /**
   * 批量更新 仓位 下属数据
   */
  void saveAllByParentId(Long parentId, List<WarehouseBinProductsItemVo> list)
    throws Exception;
  /**
   * 返回 仓位 下属多级分页
   */
  Map<String, Page<WarehouseBinProductsItemVoPages>> pagesByParentId(
    WarehouseBinProductsSearchParamPo search
  );
}
